草庐IT

c++ - 异常 : Access violation

全部标签

ruby - 如何在 EventMachine 实现中捕获异常?

我有一个与thisotherpost类似的问题我已经尝试了给定的解决方案,但无济于事。我的项目是一个使用Blather的Ruby机器人库连接到Jabber服务器。问题是,当服务器出现问题并且Blather生成异常时,整个程序退出,我没有机会捕获异常。下面是一些显示问题的简单代码。本地主机上没有运行Jabber服务器,因此Blather客户端抛出异常。我的印象是EM.error_handler{}能够拦截它,但我从未看到****ERROR消息,程序就停止了。:(#!/usr/bin/envrubyrequire'rubygems'require'blather/client/client

ruby - 使用 RSpec 我如何测试救援异常 block 的结果

我有一个方法,其中有一个begin/rescueblock。如何使用RSpec2测试救援block?classCapturerdefcapturebeginstatus=ExternalService.callreturntrueifstatus=="200"returnfalserescueException=>eLogger.log_exception(e)returnfalseendendenddescribe"#capture"docontext"anexceptionisthrown"doit"shouldlogtheexceptionandreturnfalse"doc=C

Ruby 捕获 NoMethodError 并从发生异常的地方继续执行

在Ruby中,我想在另一个对象中捕获在一个对象上生成的NoMethodError,然后将一些值返回到引发异常的位置并继续执行。有没有现成的方法可以做到这一点?我想到的最好的是:classExceptionattr_accessor:continuationendclassOuterdefhelloputs"hello"endclassInnerdefworldputs"world"enddefmethod_missing(method,*args,&block)x=callccdo|cc|e=RuntimeError.exception(method)e.continuation=cc

ruby-on-rails - 如何在 heroku worker 中捕获内存配额异常

我正在使用delayed_job来处理heroku的后台作业。有时我会超出我的内存分配,我会得到这样的东西:2011-11-16T02:41:25+00:00heroku[worker.1]:错误R14(超出内存配额)2011-11-16T02:41:45+00:00heroku[worker.1]:进程运行mem=542M(106.0%)我想优雅地处理这个。有没有办法知道我什么时候会超出我的内存限制?类似于rack-timeout会很棒谢谢! 最佳答案 我想我找到了一个很好的解决方案,从Oink中窃取了一些代码。gem。特别是这个

ruby - 引发异常 : use instance or class?

我见过使用类引发异常的Ruby代码:raiseGoatException,"Maximumof3goatsperbumpercar."其他代码使用实例:raiseGoatException.new"Noleotardfoundsuitableforgoat."这两个都是以同样的方式获救的。是否有理由使用实例而不是类? 最佳答案 没有区别;在任何一种情况下都会实例化异常类。如果您提供一个字符串,作为new的参数或作为raise的第二个参数,它会被传递给initialize并且将成为异常实例的.message。例如:classGoatE

c - 如何访问符号链接(symbolic link)的 ctime、mtime、...?

在unix上,符号链接(symboliclink)是指向另一个文件的指针。不仅文件而且符号链接(symboliclink)都有ctime、mtime、……。我知道可以访问符号链接(symboliclink)时间,因为ls显示了它。如果我使用ruby​​的File#ctime、File#mtime之一,我总是得到符号链接(symboliclink)指向的文件的属性,而不是符号链接(symboliclink)的属性。我如何在ruby​​中读取这些值?如果这在ruby​​中不可行,请告诉我如何在C中实现。在那种情况下我会编写自己的c扩展。 最佳答案

ruby - 如何序列化异常

根据ruby-doc和apidock,您可以使用to_json和json_create序列化和反序列化异常。但是在浪费了一些时间尝试使用它们之后,我仍然没有找到办法。调用exc.to_json给我一个空哈希,Exception.json_create(hash)给我这个错误:undefinedmethod'json_create'forException:类我想我可以很容易地重新创建这些函数,因为源代码可用,但我更愿意了解我做错了什么……有什么想法吗? 最佳答案 默认情况下,JSON模块不会扩展Exception。您必须要求“jso

ruby - 如何检查我的主题是否引发异常?

我目前正在subject中创建一个对象,需要测试这是否会引发异常。以下代码说明了我要实现的目标:describeMyClassdodescribe'#initialize'dosubject{MyClass.new}it{is_expected.not_toraise_error(Some::Error)}endend我有一种感觉,我正在以错误的方式处理这件事。将subject设置为新对象而不创建对象两次的首选方法是什么?更新我的问题有两个。首先,这种语法不起作用:it{is_expected.not_toraise_error}但是,在itblock中使用expect确实如此(正如J

ruby - Jekyll - 液体异常 : cannot load such file -- yajl/2. 0/yajl

我试图让Jekyll在Windows上工作,但没有成功。这是我第一次安装/使用Ruby。Ruby版本:ruby2.0.0p0(2013-02-24)[i386-mingw32](http://rubyinstaller.org/)杰基尔版本:杰基尔1.0.1当我在_config.yml中将pygments设置为false时,错误消失了。错误信息D:\Code\Jekyll\test>jekyllserveConfigurationfile:D:/Code/Jekyll/test/_config.ymlSource:D:/Code/Jekyll/testDestination:D:/Co

ruby - 在 Ruby 中自动记录异常

是否有库或简单的方法来捕获Ruby程序中抛出的异常并将其记录到文件中?我看过log4r和logger,但是两者的文档都没有提供任何有关我将如何执行此操作的示例。我远程运行这个程序并丢失了stdout和stderr的句柄,如果这些信息有帮助的话。你会推荐什么? 最佳答案 如果你想在野外散步,试试这个:classExceptionaliasreal_initinitializedefinitialize(*args)real_init*args#logtheerror(self)oritsargshereendend这将在创建时拦截新异